home *** CD-ROM | disk | FTP | other *** search
/ Total Network Tools 2002 / NextStepPublishing-TotalNetworkTools2002-Win95.iso / Archive / Misc Servers / Zope.exe / RESULTLIST.PY < prev    next >
Encoding:
Python Source  |  2000-04-14  |  6.2 KB  |  165 lines

  1. ##############################################################################
  2. # Zope Public License (ZPL) Version 1.0
  3. # -------------------------------------
  4. # Copyright (c) Digital Creations.  All rights reserved.
  5. # This license has been certified as Open Source(tm).
  6. # Redistribution and use in source and binary forms, with or without
  7. # modification, are permitted provided that the following conditions are
  8. # met:
  9. # 1. Redistributions in source code must retain the above copyright
  10. #    notice, this list of conditions, and the following disclaimer.
  11. # 2. Redistributions in binary form must reproduce the above copyright
  12. #    notice, this list of conditions, and the following disclaimer in
  13. #    the documentation and/or other materials provided with the
  14. #    distribution.
  15. # 3. Digital Creations requests that attribution be given to Zope
  16. #    in any manner possible. Zope includes a "Powered by Zope"
  17. #    button that is installed by default. While it is not a license
  18. #    violation to remove this button, it is requested that the
  19. #    attribution remain. A significant investment has been put
  20. #    into Zope, and this effort will continue if the Zope community
  21. #    continues to grow. This is one way to assure that growth.
  22. # 4. All advertising materials and documentation mentioning
  23. #    features derived from or use of this software must display
  24. #    the following acknowledgement:
  25. #      "This product includes software developed by Digital Creations
  26. #      for use in the Z Object Publishing Environment
  27. #      (http://www.zope.org/)."
  28. #    In the event that the product being advertised includes an
  29. #    intact Zope distribution (with copyright and license included)
  30. #    then this clause is waived.
  31. # 5. Names associated with Zope or Digital Creations must not be used to
  32. #    endorse or promote products derived from this software without
  33. #    prior written permission from Digital Creations.
  34. # 6. Modified redistributions of any form whatsoever must retain
  35. #    the following acknowledgment:
  36. #      "This product includes software developed by Digital Creations
  37. #      for use in the Z Object Publishing Environment
  38. #      (http://www.zope.org/)."
  39. #    Intact (re-)distributions of any official Zope release do not
  40. #    require an external acknowledgement.
  41. # 7. Modifications are encouraged but must be packaged separately as
  42. #    patches to official Zope releases.  Distributions that do not
  43. #    clearly separate the patches from the original work must be clearly
  44. #    labeled as unofficial distributions.  Modifications which do not
  45. #    carry the name Zope may be packaged in any form, as long as they
  46. #    conform to all of the clauses above.
  47. # Disclaimer
  48. #   THIS SOFTWARE IS PROVIDED BY DIGITAL CREATIONS ``AS IS'' AND ANY
  49. #   EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  50. #   IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
  51. #   PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL DIGITAL CREATIONS OR ITS
  52. #   CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  53. #   SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
  54. #   LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
  55. #   USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
  56. #   ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
  57. #   OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
  58. #   OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  59. #   SUCH DAMAGE.
  60. # This software consists of contributions made by Digital Creations and
  61. # many individuals on behalf of Digital Creations.  Specific
  62. # attributions are listed in the accompanying credits file.
  63. ##############################################################################
  64.  
  65.  
  66. class ResultList:
  67.   
  68.     def __init__(self, d, words, index, TupleType=type(())):
  69.         self._index = index
  70.         self._words = words
  71.         if (type(d) is TupleType): self._dict = { d[0] : d[1] }
  72.         else: self._dict = d
  73.     
  74.     def __len__(self): return len(self._dict)
  75.  
  76.     def __getitem__(self, key): return self._dict[key]
  77.  
  78.     def keys(self): return self._dict.keys()
  79.  
  80.     def has_key(self, key): return self._dict.has_key(key)
  81.  
  82.     def items(self): return self._dict.items()  
  83.  
  84.     def __and__(self, x):
  85.         result = {}
  86.         dict = self._dict
  87.         xdict = x._dict
  88.         xhas = xdict.has_key
  89.         for id, score in dict.items():
  90.             if xhas(id): result[id] = xdict[id]+score
  91.     
  92.         return self.__class__(result, self._words+x._words, self._index)
  93.  
  94.     def and_not(self, x):
  95.         result = {}
  96.         dict = self._dict
  97.         xdict = x._dict
  98.         xhas = xdict.has_key
  99.         for id, score in dict.items():
  100.             if not xhas(id): result[id] = score
  101.     
  102.         return self.__class__(result, self._words, self._index)
  103.   
  104.     def __or__(self, x):
  105.         result = {}
  106.         dict = self._dict
  107.         has = dict.has_key
  108.         xdict = x._dict
  109.         xhas = xdict.has_key
  110.         for id, score in dict.items():
  111.             if xhas(id): result[id] = xdict[id]+score
  112.             else: result[id] = score
  113.  
  114.         for id, score in xdict.items():
  115.             if not has(id): result[id] = score
  116.     
  117.         return self.__class__(result, self._words+x._words, self._index)
  118.  
  119.     def near(self, x):
  120.         result = {}
  121.         dict = self._dict
  122.         xdict = x._dict
  123.         xhas = xdict.has_key
  124.         positions = self._index.positions
  125.         for id, score in dict.items():
  126.             if not xhas(id): continue
  127.             p=(map(lambda i: (i,0), positions(id,self._words))+
  128.                map(lambda i: (i,1), positions(id,x._words)))
  129.             p.sort()
  130.             d = lp = 9999
  131.             li = None
  132.             lsrc = None
  133.             for i,src in p:
  134.                 if i is not li and src is not lsrc and li is not None:
  135.                     d = min(d,i-li)
  136.                 li = i
  137.                 lsrc = src
  138.             if d==lp: score = min(score,xdict[id]) # synonyms
  139.             else: score = (score+xdict[id])/d
  140.             result[id] = score
  141.     
  142.         return self.__class__(result, self._words+x._words, self._index)
  143.  
  144.